package tree;

/**
 * 404. 左叶子之和
 * <p>
 * 给定二叉树的根节点 root ，返回所有左叶子之和。
 * 注意：必须是叶子节点，没有子节点的节点才能算数
 */
public class SumOfLeftLeaves_404 {
    public int sumOfLeftLeaves(TreeNode root) {
        if (root.left == null && root.right == null) {
            return 0;
        }

        int leftVal = 0;
        if (root.left != null) {
            TreeNode tmp = root.left;
            // 必须是叶子节点才能累加
            if (tmp.left == null && tmp.right == null) {
                leftVal += tmp.val;
            } else {
                leftVal += sumOfLeftLeaves(tmp);
            }
        }

        if (root.right != null){
            leftVal += sumOfLeftLeaves(root.right);
        }
        return leftVal;
    }
}
